Project Organization
print(dir_tree(path = ".", type = "directory"))
## .
## character(0)
Site Characteristics
Copepods were collected by surface tow from sites across the Western
Atlantic at several times throughout the year. The sites are shown
below. Temperatures at the time of collection were measured using a
manual thermometer.
coords = site_data %>%
select(site, long, lat) %>%
distinct()
site_map = map_data("world") %>%
filter(region %in% c("USA", "Canada")) %>%
ggplot() +
geom_polygon(aes(x = long, y = lat, group = group),
fill = "lightgrey") +
coord_map(xlim = c(-85,-60),
ylim = c(25, 48)) +
geom_point(data = coords,
mapping = aes(x = long, y = lat, colour = site),
size = 3) +
scale_colour_manual(values = site_cols) +
labs(x = "Longitude",
y = "Latitude") +
theme_matt(base_size = 16)
site_temp_plot = full_data %>%
select(site, season, doy, collection_temp, collection_salinity) %>%
distinct() %>%
ggplot(aes(x = doy, y = collection_temp, colour = site)) +
geom_line(linewidth = 1) +
geom_point(size = 6) +
scale_colour_manual(values = site_cols) +
labs(y = "Temperature (°C)",
x = "Day of the Year") +
theme_matt() +
theme(legend.position = "right")
ggarrange(site_map, site_temp_plot, common.legend = T, legend = "bottom")

Exact locations for the sites are provided here.
site_data %>%
arrange(lat) %>%
select("Site" = site, "Region" = region, "Lat" = lat, "Long" = long) %>%
knitr::kable(align = "c")
| Key Largo |
Florida |
25.28391 |
-80.33014 |
| Manatee River |
Florida |
27.50561 |
-82.57277 |
| Ft. Hamer |
Florida |
27.52488 |
-82.43101 |
| Tyler Cove |
Maryland |
38.35083 |
-76.22902 |
| Ganey’s Wharf |
Maryland |
38.80555 |
-75.90906 |
| Esker Point |
Connecticut |
41.32081 |
-72.00166 |
| Sawyer Park |
Maine |
43.90698 |
-69.87179 |
| St. Thomas de Kent Wharf |
New Brunswick |
46.44761 |
-64.63692 |
| Ritchie Wharf |
New Brunswick |
47.00481 |
-65.56291 |
Nested within each of the three regions (South, Central, and Northern
regions) are pairs of low and high salinity sites:
data.frame("Region" = c("South", "Central", "North"),
"Low Salinity" = c("Ft. Hamer", "Ganey's Wharf", "Ritchie Wharf"),
"High Salinity" = c("Manatee River", "Tyler Cove", "St. Thomas de Kent Wharf")) %>%
knitr::kable(align = "c")
| South |
Ft. Hamer |
Manatee River |
| Central |
Ganey’s Wharf |
Tyler Cove |
| North |
Ritchie Wharf |
St. Thomas de Kent Wharf |
Â
There are fairly well-established divergences between high salinity
and low salinity populations of Acartia tonsa. These sets of
geographically proximate but isolated populations provide independent
comparisons of the effects of seasonality.
season_cols = c("early" = "grey75",
"peak" = "grey50",
"late" = "grey25")
sal_regions = data.frame(region = rep(c("South", "Central", "North"), each = 2),
site = c("Ft. Hamer", "Manatee River",
"Ganey's Wharf", "Tyler Cove",
"Ritchie Wharf", "St. Thomas de Kent Wharf"),
salinity = c("low", "high"))
sal_comps = full_data %>%
filter(site %in% sal_regions$site) %>%
inner_join(sal_regions, by = c("site")) %>%
select( region = region.y, site, salinity, season, doy, collection_temp, collection_salinity,
size, ctmax, warming_tol) %>%
mutate(salinity = fct_relevel(salinity, "low", "high"),
region = fct_relevel(region, "South", "Central", "North"))
sal_comp_temps = sal_comps %>%
select(salinity, season, region, collection_temp, collection_salinity) %>%
distinct() %>%
ggplot(aes(x = salinity, y = collection_temp, colour = season, group = season)) +
facet_wrap(region~.) +
geom_point(size = 4) +
geom_line(linewidth = 1.5) +
scale_colour_manual(values = season_cols) +
labs(y = "Collection Temp. (°C)",
x = "") +
theme_matt_facets(base_size = 14)
sal_comp_sal = sal_comps %>%
select(salinity, season, region, collection_temp, collection_salinity) %>%
distinct() %>%
ggplot(aes(x = salinity, y = collection_salinity, colour = season, group = season)) +
facet_wrap(region~.) +
geom_point(size = 4) +
geom_line(linewidth = 1.5) +
scale_colour_manual(values = season_cols) +
labs(y = "Collection Salinity (psu)",
x = "Salinity") +
theme_matt_facets(base_size = 14)
ggarrange(sal_comp_temps, sal_comp_sal, nrow = 2, common.legend = T, legend = "right")

# sal_comps %>%
# select(site, salinity, season, region, collection_temp, collection_salinity) %>%
# distinct() %>%
# ggplot(aes(x = collection_salinity, y = collection_temp, colour = site)) +
# facet_grid(region~.) +
# geom_point(size = 4) +
# #stat_ellipse() +
# #geom_path(arrow = arrow(length = unit(0.1, "inches"), type = "closed")) +
# scale_colour_manual(values = site_cols) +
# theme_matt_facets(base_size = 14)
Critical Thermal Limits
A total of 308 individuals were examined. Critical thermal limits and
body size measurements were made before individuals were preserved in
ethanol. We excluded data for 5 individuals, detailed below. These
individuals had either very low CTmax or were, upon re-examination of
photographs, identified as juveniles instead of mature females.
excluded %>%
select(region, site, season, collection_temp, collection_salinity, replicate, tube, ctmax, size) %>%
knitr::kable(align = "c")
| Florida |
Manatee River |
peak |
34.0 |
29 |
2 |
6 |
38.45833 |
0.616 |
| Florida |
Manatee River |
peak |
34.0 |
29 |
2 |
7 |
38.23750 |
0.593 |
| Maryland |
Tyler Cove |
peak |
29.5 |
15 |
2 |
2 |
36.84375 |
0.614 |
| Connecticut |
Esker Point |
early |
22.5 |
30 |
2 |
3 |
30.02604 |
0.687 |
| Maine |
Sawyer Park |
peak |
22.0 |
30 |
1 |
4 |
30.81424 |
0.865 |
Critical thermal maxima (CTmax) was measured using a custom setup.
The method uses a standard dynamic ramping assay to determine the
maximum temperature individuals could sustain normal functioning. This
differs from lethal temperatures, and indeed, all individuals observed
so far recovered following the assay.
Individuals were rested for one hour after collection before the
assay. During the assay, copepods were held in 0.2 um filtered seawater,
adjusted to match the salinity at the time of collection with bottled
spring water. During the assay, several ‘control’ individuals were
maintained in this adjusted salinity solution, but did not experience
the temperature ramp, to ensure that there was no background
mortality.
Shown below are the measured CTmax values. Note: CTmax values for the
early season Key Largo copepods were collected at the end of February
2023 as part of a separate project. Body size values were not measured
during this project, nor were copepods individually preserved after the
experiments. These early season CTmax values are included as a point of
comparison.
mean_ctmax = full_data %>%
group_by(site, season) %>%
summarize(mean_ctmax = mean(ctmax))
ggplot(full_data, aes(x = season, y = ctmax, colour = site)) +
geom_line(data = mean_ctmax,
aes(y = mean_ctmax, group = site),
position = position_dodge(width = 0.4),
linewidth = 1) +
geom_point(position = position_jitterdodge(jitter.width = 0.1, jitter.height = 0,
dodge.width = 0.4),
alpha = 0.3) +
geom_point(data = mean_ctmax,
aes(y = mean_ctmax),
position = position_dodge(width = 0.4),
size = 4) +
scale_colour_manual(values = site_cols) +
labs(y = "CTmax (°C)",
x = "Season") +
theme_matt() +
theme(legend.position = "right",
legend.title.align = 0.125)

Warming tolerance
Warming tolerance was calculated as the difference between measured
CTmax values and the collection temperature. Lower warming tolerance
values indicate that populations were nearer to their upper thermal
limits, and may therefore be more vulnerable to additional warming.
mean_wt = full_data %>%
group_by(site, season) %>%
summarize(mean_wt = mean(warming_tol))
ggplot(full_data, aes(x = season, y = warming_tol, colour = site)) +
geom_line(data = mean_wt,
aes(y = mean_wt, group = site),
position = position_dodge(width = 0.4),
linewidth = 1) +
geom_point(position = position_jitterdodge(jitter.width = 0.1, jitter.height = 0,
dodge.width = 0.4),
alpha = 0.3) +
geom_point(data = mean_wt,
aes(y = mean_wt),
position = position_dodge(width = 0.4),
size = 4) +
scale_colour_manual(values = site_cols) +
labs(y = "Warming Tolerance (°C)",
x = "Season") +
theme_matt() +
theme(legend.position = "right",
legend.title.align = 0.125)

Body Size
Following the CTmax assay, individuals were photographed for body
size measurements. Prosome lengths were measured from these photographs
using a scale micrometer and the software ImageJ. These measurements are
shown below.
mean_size = full_data %>%
group_by(site, season) %>%
summarize(mean_size = mean(size))
ggplot(full_data, aes(x = season, y = size, colour = site)) +
geom_line(data = mean_size,
aes(y = mean_size, group = site),
position = position_dodge(width = 0.4),
linewidth = 1) +
geom_point(position = position_jitterdodge(jitter.width = 0.1, jitter.height = 0,
dodge.width = 0.4),
alpha = 0.3) +
geom_point(data = mean_size,
aes(y = mean_size),
position = position_dodge(width = 0.4),
size = 4) +
scale_colour_manual(values = site_cols) +
labs(y = "Prosome Length (mm)",
x = "Season") +
theme_matt() +
theme(legend.position = "right",
legend.title.align = 0.125)

Salinity Pair Comparisons
sal_comp_ctmax_plot = sal_comps %>%
ggplot(aes(x = salinity, y = ctmax, colour = season, group = season)) +
facet_wrap(region~.) +
geom_point(size = 2,
position = position_dodge(width = 0.2)) +
#geom_line(size = 1.5) +
scale_colour_manual(values = season_cols) +
labs(y = "CTmax (°C)",
x = "") +
theme_matt_facets(base_size = 14)
sal_comp_size_plot = sal_comps %>%
ggplot(aes(x = salinity, y = size, colour = season, group = season)) +
facet_wrap(region~.) +
geom_point(size = 2,
position = position_dodge(width = 0.2)) +
#geom_line(size = 1.5) +
scale_colour_manual(values = season_cols) +
labs(y = "Prosome Length (mm)",
x = "") +
theme_matt_facets(base_size = 14)
ggarrange(sal_comp_ctmax_plot, sal_comp_size_plot, nrow = 2, common.legend = T, legend = "right")

###
sal_comp_ctmax.model = lm(ctmax ~ collection_temp, data = sal_comps)
# summary(ctmax_temp.model)
# car::Anova(ctmax_temp.model)
sal_comp_ctmax_resids = residuals(sal_comp_ctmax.model)
sal_comp_size.model = lm(size ~ collection_temp, data = sal_comps)
# summary(size_temp.model)
# car::Anova(size_temp.model)
sal_comp_size_resids = residuals(sal_comp_size.model)
sal_comp_ctmax_resid_plot = sal_comps %>%
mutate(ctmax_resids = sal_comp_ctmax_resids,
size_resids = sal_comp_size_resids) %>%
ggplot(aes(x = salinity, y = ctmax_resids, colour = season, group = season)) +
facet_wrap(region~.) +
geom_point(size = 2,
position = position_dodge(width = 0.5)) +
#geom_line(size = 1.5) +
scale_colour_manual(values = season_cols) +
labs(y = "CTmax \nResiduals",
x = "") +
theme_matt_facets(base_size = 14)
sal_comp_size_resid_plot = sal_comps %>%
mutate(ctmax_resids = sal_comp_ctmax_resids,
size_resids = sal_comp_size_resids) %>%
ggplot(aes(x = salinity, y = size_resids, colour = season, group = season)) +
facet_wrap(region~.) +
geom_point(size = 2,
position = position_dodge(width = 0.5)) +
#geom_line(size = 1.5) +
scale_colour_manual(values = season_cols) +
labs(y = "Prosome Length \nResiduals",
x = "") +
theme_matt_facets(base_size = 14)
#ggarrange(sal_comp_ctmax_resid_plot, sal_comp_size_resid_plot, nrow = 2, common.legend = T, legend = "right")
Trait Correlations
We expect that collections from warmer waters should yield copepods
with higher thermal limits and smaller body sizes.
ctmax_temp_plot = ggplot(full_data, aes(x = collection_temp, y = ctmax)) +
geom_smooth(method = "lm", se = T,
linewidth = 2,
colour = "grey") +
geom_point(aes(colour = site),
size = 2, alpha = 0.7) +
scale_colour_manual(values = site_cols) +
labs(y = "CTmax (°C)",
x = "Collection Temp. (°C)") +
theme_matt() +
theme(legend.position = "right")
size_temp_plot = ggplot(full_data, aes(x = collection_temp, y = size)) +
geom_smooth(method = "lm", se = T,
linewidth = 2,
colour = "grey") +
geom_point(aes(colour = site),
size = 2, alpha = 0.7) +
scale_colour_manual(values = site_cols) +
labs(y = "Prosome Length (mm)",
x = "Collection Temp. (°C)") +
theme_matt() +
theme(legend.position = "right")
wt_temp_plot = ggplot(full_data, aes(x = collection_temp, y = warming_tol)) +
geom_smooth(method = "lm", se = T,
linewidth = 2,
colour = "grey") +
geom_point(aes(colour = site),
size = 2, alpha = 0.7) +
scale_colour_manual(values = site_cols) +
labs(y = "Warming Tolerance (°C)",
x = "Collection Temp. (°C)") +
theme_matt() +
theme(legend.position = "right")
ggarrange(ctmax_temp_plot, wt_temp_plot, size_temp_plot, common.legend = T, legend = "bottom", nrow = 1)

Of particular interest is the relationship between prosome length and
CTmax. In many cases, larger body sizes are associated with cold
adaptation/acclimation. We may therefore see this pattern emerge across
populations or seasons. If populations contain a mix of cold- and
warm-adapted genotypes, however, we might also see this relationship
emerge within individual collections. Shown below is
the relationship between prosome length and CTmax for the individuals
measured thus far. Individual regression lines for each site are also
included. Note that raw CTmax and body size values are shown, rather
than metrics like residuals from a statistical model correcting for
variation in collection temperature.
universal_size = full_data %>%
ggplot(aes(x = size, y = ctmax)) +
# geom_smooth(data = filter(full_data, ctmax > 31),
# aes(x = size, y = ctmax),
# method = "lm",
# colour = "grey60",
# se = F,
# linewidth = 2) +
geom_smooth(method = "lm", se = T,
linewidth = 2,
colour = "grey70") +
geom_point(aes(colour = site),
size = 2, alpha = 0.7) +
scale_colour_manual(values = site_cols) +
labs(y = "CTmax (°C)",
x = "") +
theme_matt(base_size = 14) +
theme(legend.position = "right",
axis.title.x = element_blank())
pop_size = full_data %>%
ggplot(aes(x = size, y = ctmax, colour = site, group = season)) +
facet_wrap(site~.) +
# geom_smooth(data = filter(full_data, ctmax > 31),
# aes(x = size, y = ctmax),
# method = "lm",
# colour = "grey60",
# se = F,
# linewidth = 2) +
geom_point(size = 1.3, alpha = 0.3) +
geom_smooth(method = "lm", se = F,
linewidth = 1) +
scale_colour_manual(values = site_cols) +
scale_x_continuous(breaks = c(0.6, 0.8, 1)) +
labs(y = "CTmax (°C)",
x = "Prosome Length (mm)") +
theme_matt(base_size = 14) +
theme(legend.position = "right")
ggarrange(universal_size, pop_size, common.legend = T, legend = "none", nrow = 2)

Trait Variability
Shown below is the trait variation (ranges) for each site. Ranges are
calculated for each season separately.
trait_ranges = full_data %>%
group_by(site, season, collection_temp, collection_salinity, doy, lat) %>%
summarise(mean_ctmax = mean(ctmax),
ctmax_range = max(ctmax) - min(ctmax),
ctmax_var = var(ctmax),
mean_size = mean(size),
size_range = max(size) - min(size),
size_var = var(size)) %>%
mutate(prop_ctmax_range = ctmax_range / mean_ctmax,
prop_size_range = size_range / mean_size)
ctmax_range_temp = ggplot(trait_ranges, aes(x = collection_temp, y = ctmax_range, colour = site)) +
geom_point(size = 3) +
scale_colour_manual(values = site_cols) +
labs(y = "CTmax Range (°C)",
x = "Collection Temp. (°C)") +
theme_matt() +
theme(legend.position = "right")
ctmax_var_temp = ggplot(trait_ranges, aes(x = collection_temp, y = ctmax_var, colour = site)) +
geom_point(size = 3) +
scale_colour_manual(values = site_cols) +
labs(y = "CTmax Range (°C)",
x = "Collection Temp. (°C)") +
theme_matt() +
theme(legend.position = "right")
size_range_temp = ggplot(trait_ranges, aes(x = collection_temp, y = size_range, colour = site)) +
geom_point(size = 3) +
scale_colour_manual(values = site_cols) +
labs(y = "Size Range (mm)",
x = "Collection Temp. (°C)") +
theme_matt() +
theme(legend.position = "right")
ggarrange(ctmax_range_temp, size_range_temp, common.legend = T, legend = "bottom")

Changes in trait variance may be indicative of phenotypic selection.
If selection (as opposed to acclimation) are driving seasonal changes,
we may expect to see a reduction in variance in the peak samples
relative to the early season samples. Note that early season collection
temperatures this year were higher than expected, driven by fairly
strong heatwaves in the North Atlantic.
ggplot(trait_ranges, aes(x = season, y = ctmax_var, colour = site)) +
geom_line(aes(group = site),
linewidth = 1.5) +
geom_point(size = 3) +
scale_colour_manual(values = site_cols) +
labs(y = "CTmax Variance",
x = "Season") +
theme_matt() +
theme(legend.position = "right",
legend.title.align = 0.125)

Next Steps
After phenotyping, each individual was preserved in 95% ethanol.
Individual DNA libraries will be prepared using Twist Bio 96-plex prep
kits, then sequenced on an Illumina NovaSeq X Plus. Using the
low-coverage whole genome sequences, we will examine seasonal patterns
in allele frequency change, and compare these fine scale temporal
patterns with the larger latitudinal patterns in allele frequency to
determine whether the same alleles driving rapid seasonal adaptation are
in play over larger spatial (and longer temporal) scales.
Misc. Details
ggplot(temp_record, aes(x = minute_passed, y = temp_C, group = factor(run))) +
geom_abline(slope = 0.3, intercept = mean(temp_record[temp_record$minute_interval == 0, 8])) +
geom_abline(slope = 0.1, intercept = mean(temp_record[temp_record$minute_interval == 0, 8])) +
geom_line(linewidth = 0.2, alpha = 0.8) +
geom_point(data = full_data,
aes(x = time, y = ctmax + 0.4),
size = 2,
shape = 25) +
labs(x = "Time passed (minutes)",
y = "Temperature (degrees C)",
fill = "Trial Number") +
guides(colour = "none") +
theme_matt(base_size = 16) +
theme(legend.position = "right")

ramp_record2 = ramp_record %>%
group_by(run, minute_interval) %>%
summarise(mean_ramp = mean(ramp_per_minute)) %>%
ungroup()
ggplot(ramp_record2, aes(x = minute_interval, y = mean_ramp)) +
geom_hline(yintercept = 0.3) +
geom_hline(yintercept = 0.1) +
#geom_point() +
geom_hex(bins = 30) +
ylim(0, 0.35) +
labs(y = "Ramp Rate (deg. C / min.)",
x = "Time into run (minute)") +
theme_matt(base_size = 16)

LS0tCnRpdGxlOiAiQ29tcGFyaW5nIHNlYXNvbmFsIGFuZCBsYXRpdHVkaW5hbCBwYXR0ZXJucyBpbiB0aGVybWFsIGFkYXB0YXRpb24iCmRhdGU6ICJgciBTeXMuRGF0ZSgpYCIKb3V0cHV0OiAKICBodG1sX2RvY3VtZW50OgogICAgICAgICAgY29kZV9mb2xkaW5nOiBoaWRlCiAgICAgICAgICBjb2RlX2Rvd25sb2FkOiB0cnVlCiAgICAgICAgICB0b2M6IHRydWUKICAgICAgICAgIHRvY19mbG9hdDogdHJ1ZQogIGdpdGh1Yl9kb2N1bWVudDoKICAgICAgICAgIGh0bWxfcHJldmlldzogZmFsc2UKICAgICAgICAgIHRvYzogdHJ1ZQogICAgICAgICAgdG9jX2RlcHRoOiAzCi0tLQoKYGBge3Igc2V0dXAsIGluY2x1ZGU9VCwgbWVzc2FnZSA9IEYsIHdhcm5pbmcgPSBGLCBlY2hvID0gRn0KCmtuaXRyOjpvcHRzX2NodW5rJHNldCgKICBlY2hvID0ga25pdHI6OmlzX2h0bWxfb3V0cHV0KCksCiAgZmlnLmFsaWduID0gImNlbnRlciIsCiAgZmlnLnBhdGggPSAiLi4vRmlndXJlcy9tYXJrZG93bi8iLAogIGRldiA9IGMoInBuZyIsICJwZGYiKSwKICBtZXNzYWdlID0gRkFMU0UsCiAgd2FybmluZyA9IEZBTFNFLAogIGNvbGxhcHNlID0gVAopCgp0aGVtZV9tYXR0ID0gZnVuY3Rpb24oYmFzZV9zaXplID0gMTgsCiAgICAgICAgICAgICAgICAgICAgICBkYXJrX3RleHQgPSAiZ3JleTIwIil7CiAgbWlkX3RleHQgPC0gIG1vbm9jaHJvbWVSOjpnZW5lcmF0ZV9wYWxldHRlKGRhcmtfdGV4dCwgImdvX2xpZ2h0ZXIiLCBuX2NvbG91cnMgPSA1KVsyXQogIGxpZ2h0X3RleHQgPC0gIG1vbm9jaHJvbWVSOjpnZW5lcmF0ZV9wYWxldHRlKGRhcmtfdGV4dCwgImdvX2xpZ2h0ZXIiLCBuX2NvbG91cnMgPSA1KVszXQogIAogIHRoZW1lX3B1YnIoYmFzZV9mYW1pbHk9InNhbnMiKSAlK3JlcGxhY2UlIAogICAgdGhlbWUoCiAgICAgIHBhbmVsLmJhY2tncm91bmQgID0gZWxlbWVudF9yZWN0KGZpbGw9InRyYW5zcGFyZW50IiwgY29sb3VyPU5BKSwgCiAgICAgIHBsb3QuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsPSJ0cmFuc3BhcmVudCIsIGNvbG91cj1OQSksIAogICAgICBsZWdlbmQuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsPSJ0cmFuc3BhcmVudCIsIGNvbG91cj1OQSksCiAgICAgIGxlZ2VuZC5rZXkgPSBlbGVtZW50X3JlY3QoZmlsbD0idHJhbnNwYXJlbnQiLCBjb2xvdXI9TkEpLAogICAgICB0ZXh0ID0gZWxlbWVudF90ZXh0KGNvbG91ciA9IG1pZF90ZXh0LCBsaW5laGVpZ2h0ID0gMS4xKSwKICAgICAgdGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IGJhc2Vfc2l6ZSAqIDEuNSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgY29sb3VyID0gZGFya190ZXh0KSwKICAgICAgYXhpcy50ZXh0ID0gZWxlbWVudF90ZXh0KHNpemUgPSBiYXNlX3NpemUsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjb2xvdXIgPSBtaWRfdGV4dCksCiAgICAgIGF4aXMudGl0bGUueCA9IGVsZW1lbnRfdGV4dChzaXplID0gYmFzZV9zaXplICogMS4yLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWFyZ2luID0gdW5pdChjKDMsIDAsIDAsIDApLCAibW0iKSksCiAgICAgIGF4aXMudGl0bGUueSA9IGVsZW1lbnRfdGV4dChzaXplID0gYmFzZV9zaXplICogMS4yLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbWFyZ2luID0gdW5pdChjKDAsIDUsIDAsIDApLCAibW0iKSwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBhbmdsZSA9IDkwKSwKICAgICAgbGVnZW5kLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZT1iYXNlX3NpemUgKiAwLjkpLAogICAgICBsZWdlbmQudGl0bGUgPSBlbGVtZW50X3RleHQoc2l6ZSA9IGJhc2Vfc2l6ZSAqIDAuOSwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmYWNlID0gImJvbGQiKSwKICAgICAgcGxvdC5tYXJnaW4gPSBtYXJnaW4oMC4yNSwgMC4yNSwgMC4yNSwgMC4yNSwiY20iKQogICAgKQp9Cgp0aGVtZV9tYXR0X2ZhY2V0cyA9IGZ1bmN0aW9uKGJhc2Vfc2l6ZSA9IDE4LAogICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRhcmtfdGV4dCA9ICJncmV5MjAiKXsKICBtaWRfdGV4dCA8LSAgbW9ub2Nocm9tZVI6OmdlbmVyYXRlX3BhbGV0dGUoZGFya190ZXh0LCAiZ29fbGlnaHRlciIsIG5fY29sb3VycyA9IDUpWzJdCiAgbGlnaHRfdGV4dCA8LSAgbW9ub2Nocm9tZVI6OmdlbmVyYXRlX3BhbGV0dGUoZGFya190ZXh0LCAiZ29fbGlnaHRlciIsIG5fY29sb3VycyA9IDUpWzNdCiAgCiAgdGhlbWVfYncoYmFzZV9mYW1pbHk9InNhbnMiKSAlK3JlcGxhY2UlIAogICAgdGhlbWUoCiAgICAgIHBhbmVsLmdyaWQgPSBlbGVtZW50X2JsYW5rKCksCiAgICAgIHBhbmVsLmJhY2tncm91bmQgID0gZWxlbWVudF9yZWN0KGZpbGw9InRyYW5zcGFyZW50IiwgY29sb3VyPU5BKSwgCiAgICAgIHBsb3QuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsPSJ0cmFuc3BhcmVudCIsIGNvbG91cj1OQSksIAogICAgICBsZWdlbmQuYmFja2dyb3VuZCA9IGVsZW1lbnRfcmVjdChmaWxsPSJ0cmFuc3BhcmVudCIsIGNvbG91cj1OQSksCiAgICAgIGxlZ2VuZC5rZXkgPSBlbGVtZW50X3JlY3QoZmlsbD0idHJhbnNwYXJlbnQiLCBjb2xvdXI9TkEpLAogICAgICB0ZXh0ID0gZWxlbWVudF90ZXh0KGNvbG91ciA9IG1pZF90ZXh0LCBsaW5laGVpZ2h0ID0gMS4xKSwKICAgICAgc3RyaXAudGV4dC54ID0gZWxlbWVudF90ZXh0KHNpemUgPSBiYXNlX3NpemUpLAogICAgICB0aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gYmFzZV9zaXplICogMS41LAogICAgICAgICAgICAgICAgICAgICAgICAgICBjb2xvdXIgPSBkYXJrX3RleHQpLAogICAgICBheGlzLnRleHQgPSBlbGVtZW50X3RleHQoc2l6ZSA9IGJhc2Vfc2l6ZSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNvbG91ciA9IG1pZF90ZXh0KSwKICAgICAgYXhpcy50aXRsZS54ID0gZWxlbWVudF90ZXh0KHNpemUgPSBiYXNlX3NpemUgKiAxLjIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBtYXJnaW4gPSB1bml0KGMoMywgMCwgMCwgMCksICJtbSIpKSwKICAgICAgYXhpcy50aXRsZS55ID0gZWxlbWVudF90ZXh0KHNpemUgPSBiYXNlX3NpemUgKiAxLjIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBtYXJnaW4gPSB1bml0KGMoMCwgNSwgMCwgMCksICJtbSIpLCAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGFuZ2xlID0gOTApLAogICAgICBsZWdlbmQudGV4dCA9IGVsZW1lbnRfdGV4dChzaXplPWJhc2Vfc2l6ZSAqIDAuOSksCiAgICAgIGxlZ2VuZC50aXRsZSA9IGVsZW1lbnRfdGV4dChzaXplID0gYmFzZV9zaXplICogMC45LCAKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZhY2UgPSAiYm9sZCIpLAogICAgICBwbG90Lm1hcmdpbiA9IG1hcmdpbigwLjI1LCAwLjI1LCAwLjI1LCAwLjI1LCJjbSIpCiAgICApCn0KCnNpdGVfY29scyA9IGMoIktleSBMYXJnbyIgPSAiaW5kaWFucmVkNCIsIAogICAgICAgICAgICAgICJNYW5hdGVlIFJpdmVyIiA9ICJjb3JhbCIsIAogICAgICAgICAgICAgICJGdC4gSGFtZXIiID0gImNvcmFsMyIsCiAgICAgICAgICAgICAgIlR5bGVyIENvdmUiID0gImdvbGRlbnJvZDEiLAogICAgICAgICAgICAgICJHYW5leSdzIFdoYXJmIiA9ICJkYXJrZ29sZGVucm9kMyIsIAogICAgICAgICAgICAgICJFc2tlciBQb2ludCIgPSAiZGFya3NlYWdyZWVuMyIsCiAgICAgICAgICAgICAgIlNhd3llciBQYXJrIiA9ICJwYWxlZ3JlZW40IiwgCiAgICAgICAgICAgICAgIlN0LiBUaG9tYXMgZGUgS2VudCBXaGFyZiIgPSAic3RlZWxibHVlMiIsCiAgICAgICAgICAgICAgIlJpdGNoaWUgV2hhcmYiID0gInN0ZWVsYmx1ZTQiKQpgYGAKCiMjIFByb2plY3QgT3JnYW5pemF0aW9uCmBgYHtyfQpwcmludChkaXJfdHJlZShwYXRoID0gIi4iLCB0eXBlID0gImRpcmVjdG9yeSIpKQpgYGAKCgoKIyMgU2l0ZSBDaGFyYWN0ZXJpc3RpY3MKCkNvcGVwb2RzIHdlcmUgY29sbGVjdGVkIGJ5IHN1cmZhY2UgdG93IGZyb20gc2l0ZXMgYWNyb3NzIHRoZSBXZXN0ZXJuIEF0bGFudGljIGF0IHNldmVyYWwgdGltZXMgdGhyb3VnaG91dCB0aGUgeWVhci4gVGhlIHNpdGVzIGFyZSBzaG93biBiZWxvdy4gVGVtcGVyYXR1cmVzIGF0IHRoZSB0aW1lIG9mIGNvbGxlY3Rpb24gd2VyZSBtZWFzdXJlZCB1c2luZyBhIG1hbnVhbCB0aGVybW9tZXRlci4KCmBgYHtyIHNpdGUtY2hhcnMsIGZpZy53aWR0aD0xMCwgZmlnLmhlaWdodD02fQpjb29yZHMgPSBzaXRlX2RhdGEgJT4lCiAgc2VsZWN0KHNpdGUsIGxvbmcsIGxhdCkgJT4lCiAgZGlzdGluY3QoKQoKc2l0ZV9tYXAgPSBtYXBfZGF0YSgid29ybGQiKSAlPiUgCiAgZmlsdGVyKHJlZ2lvbiAlaW4lIGMoIlVTQSIsICJDYW5hZGEiKSkgJT4lIAogIGdncGxvdCgpICsgCiAgZ2VvbV9wb2x5Z29uKGFlcyh4ID0gbG9uZywgeSA9IGxhdCwgZ3JvdXAgPSBncm91cCksCiAgICAgICAgICAgICAgIGZpbGwgPSAibGlnaHRncmV5IikgKyAKICBjb29yZF9tYXAoeGxpbSA9IGMoLTg1LC02MCksCiAgICAgICAgICAgIHlsaW0gPSBjKDI1LCA0OCkpICsgCiAgZ2VvbV9wb2ludChkYXRhID0gY29vcmRzLAogICAgICAgICAgICAgbWFwcGluZyA9IGFlcyh4ID0gbG9uZywgeSA9IGxhdCwgY29sb3VyID0gc2l0ZSksCiAgICAgICAgICAgICBzaXplID0gMykgKwogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeCA9ICJMb25naXR1ZGUiLCAKICAgICAgIHkgPSAiTGF0aXR1ZGUiKSArIAogIHRoZW1lX21hdHQoYmFzZV9zaXplID0gMTYpCgpzaXRlX3RlbXBfcGxvdCA9IGZ1bGxfZGF0YSAlPiUgCiAgc2VsZWN0KHNpdGUsIHNlYXNvbiwgZG95LCBjb2xsZWN0aW9uX3RlbXAsIGNvbGxlY3Rpb25fc2FsaW5pdHkpICU+JSAgCiAgZGlzdGluY3QoKSAlPiUgCiAgZ2dwbG90KGFlcyh4ID0gZG95LCB5ID0gY29sbGVjdGlvbl90ZW1wLCBjb2xvdXIgPSBzaXRlKSkgKyAKICBnZW9tX2xpbmUobGluZXdpZHRoID0gMSkgKyAKICBnZW9tX3BvaW50KHNpemUgPSA2KSArCiAgc2NhbGVfY29sb3VyX21hbnVhbCh2YWx1ZXMgPSBzaXRlX2NvbHMpICsgCiAgbGFicyh5ID0gIlRlbXBlcmF0dXJlICjCsEMpIiwKICAgICAgIHggPSAiRGF5IG9mIHRoZSBZZWFyIikgKwogIHRoZW1lX21hdHQoKSArIAogIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9ICJyaWdodCIpCgpnZ2FycmFuZ2Uoc2l0ZV9tYXAsIHNpdGVfdGVtcF9wbG90LCBjb21tb24ubGVnZW5kID0gVCwgbGVnZW5kID0gImJvdHRvbSIpCmBgYAoKRXhhY3QgbG9jYXRpb25zIGZvciB0aGUgc2l0ZXMgYXJlIHByb3ZpZGVkIGhlcmUuIAoKYGBge3Igc2l0ZS10YWJsZX0Kc2l0ZV9kYXRhICU+JSAgCiAgYXJyYW5nZShsYXQpICU+JSAgCiAgc2VsZWN0KCJTaXRlIiA9IHNpdGUsICJSZWdpb24iID0gcmVnaW9uLCAiTGF0IiA9IGxhdCwgIkxvbmciID0gbG9uZykgJT4lIAogIGtuaXRyOjprYWJsZShhbGlnbiA9ICJjIikKYGBgCgpOZXN0ZWQgd2l0aGluIGVhY2ggb2YgdGhlIHRocmVlIHJlZ2lvbnMgKFNvdXRoLCBDZW50cmFsLCBhbmQgTm9ydGhlcm4gcmVnaW9ucykgYXJlIHBhaXJzIG9mIGxvdyBhbmQgaGlnaCBzYWxpbml0eSBzaXRlczogICAgCgpgYGB7ciBzYWwtdGFibGV9CmRhdGEuZnJhbWUoIlJlZ2lvbiIgPSBjKCJTb3V0aCIsICJDZW50cmFsIiwgIk5vcnRoIiksCiAgICAgICAgICAgIkxvdyBTYWxpbml0eSIgPSBjKCJGdC4gSGFtZXIiLCAiR2FuZXkncyBXaGFyZiIsICJSaXRjaGllIFdoYXJmIiksCiAgICAgICAgICAgIkhpZ2ggU2FsaW5pdHkiID0gYygiTWFuYXRlZSBSaXZlciIsICJUeWxlciBDb3ZlIiwgIlN0LiBUaG9tYXMgZGUgS2VudCBXaGFyZiIpKSAlPiUgCiAga25pdHI6OmthYmxlKGFsaWduID0gImMiKQpgYGAKClwgCgpUaGVyZSBhcmUgZmFpcmx5IHdlbGwtZXN0YWJsaXNoZWQgZGl2ZXJnZW5jZXMgYmV0d2VlbiBoaWdoIHNhbGluaXR5IGFuZCBsb3cgc2FsaW5pdHkgcG9wdWxhdGlvbnMgb2YgKkFjYXJ0aWEgdG9uc2EqLiBUaGVzZSBzZXRzIG9mIGdlb2dyYXBoaWNhbGx5IHByb3hpbWF0ZSBidXQgaXNvbGF0ZWQgcG9wdWxhdGlvbnMgcHJvdmlkZSBpbmRlcGVuZGVudCBjb21wYXJpc29ucyBvZiB0aGUgZWZmZWN0cyBvZiBzZWFzb25hbGl0eS4KCmBgYHtyIHNlYXNvbi1zYWwtY29tcHMsIGZpZy53aWR0aD04LCBmaWcuaGVpZ2h0PTh9CnNlYXNvbl9jb2xzID0gYygiZWFybHkiID0gImdyZXk3NSIsIAogICAgICAgICAgICAgICAgInBlYWsiID0gImdyZXk1MCIsIAogICAgICAgICAgICAgICAgImxhdGUiID0gImdyZXkyNSIpCgpzYWxfcmVnaW9ucyA9IGRhdGEuZnJhbWUocmVnaW9uID0gcmVwKGMoIlNvdXRoIiwgIkNlbnRyYWwiLCAiTm9ydGgiKSwgZWFjaCA9IDIpLCAKICAgICAgICAgICAgICAgICAgICAgICAgIHNpdGUgPSBjKCJGdC4gSGFtZXIiLCAiTWFuYXRlZSBSaXZlciIsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIkdhbmV5J3MgV2hhcmYiLCAiVHlsZXIgQ292ZSIsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIlJpdGNoaWUgV2hhcmYiLCAiU3QuIFRob21hcyBkZSBLZW50IFdoYXJmIiksCiAgICAgICAgICAgICAgICAgICAgICAgICBzYWxpbml0eSA9IGMoImxvdyIsICJoaWdoIikpCgpzYWxfY29tcHMgPSBmdWxsX2RhdGEgJT4lIAogIGZpbHRlcihzaXRlICVpbiUgc2FsX3JlZ2lvbnMkc2l0ZSkgJT4lIAogIGlubmVyX2pvaW4oc2FsX3JlZ2lvbnMsIGJ5ID0gYygic2l0ZSIpKSAlPiUgCiAgc2VsZWN0KCByZWdpb24gPSByZWdpb24ueSwgc2l0ZSwgc2FsaW5pdHksIHNlYXNvbiwgZG95LCBjb2xsZWN0aW9uX3RlbXAsIGNvbGxlY3Rpb25fc2FsaW5pdHksCiAgICAgICAgICBzaXplLCBjdG1heCwgd2FybWluZ190b2wpICU+JSAKICBtdXRhdGUoc2FsaW5pdHkgPSBmY3RfcmVsZXZlbChzYWxpbml0eSwgImxvdyIsICJoaWdoIiksCiAgICAgICAgIHJlZ2lvbiA9IGZjdF9yZWxldmVsKHJlZ2lvbiwgIlNvdXRoIiwgIkNlbnRyYWwiLCAiTm9ydGgiKSkKCnNhbF9jb21wX3RlbXBzID0gc2FsX2NvbXBzICU+JSAgCiAgc2VsZWN0KHNhbGluaXR5LCBzZWFzb24sIHJlZ2lvbiwgY29sbGVjdGlvbl90ZW1wLCBjb2xsZWN0aW9uX3NhbGluaXR5KSAlPiUgCiAgZGlzdGluY3QoKSAlPiUgCiAgZ2dwbG90KGFlcyh4ID0gc2FsaW5pdHksIHkgPSBjb2xsZWN0aW9uX3RlbXAsIGNvbG91ciA9IHNlYXNvbiwgZ3JvdXAgPSBzZWFzb24pKSArIAogIGZhY2V0X3dyYXAocmVnaW9ufi4pICsgCiAgZ2VvbV9wb2ludChzaXplID0gNCkgKyAKICBnZW9tX2xpbmUobGluZXdpZHRoID0gMS41KSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2Vhc29uX2NvbHMpICsgCiAgbGFicyh5ID0gIkNvbGxlY3Rpb24gVGVtcC4gKMKwQykiLAogICAgICAgeCA9ICIiKSArIAogIHRoZW1lX21hdHRfZmFjZXRzKGJhc2Vfc2l6ZSA9IDE0KQoKc2FsX2NvbXBfc2FsID0gc2FsX2NvbXBzICU+JSAgCiAgc2VsZWN0KHNhbGluaXR5LCBzZWFzb24sIHJlZ2lvbiwgY29sbGVjdGlvbl90ZW1wLCBjb2xsZWN0aW9uX3NhbGluaXR5KSAlPiUgCiAgZGlzdGluY3QoKSAlPiUgCiAgZ2dwbG90KGFlcyh4ID0gc2FsaW5pdHksIHkgPSBjb2xsZWN0aW9uX3NhbGluaXR5LCBjb2xvdXIgPSBzZWFzb24sIGdyb3VwID0gc2Vhc29uKSkgKyAKICBmYWNldF93cmFwKHJlZ2lvbn4uKSArIAogIGdlb21fcG9pbnQoc2l6ZSA9IDQpICsgCiAgZ2VvbV9saW5lKGxpbmV3aWR0aCA9IDEuNSkgKyAKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNlYXNvbl9jb2xzKSArIAogIGxhYnMoeSA9ICJDb2xsZWN0aW9uIFNhbGluaXR5IChwc3UpIiwKICAgICAgIHggPSAiU2FsaW5pdHkiKSArIAogIHRoZW1lX21hdHRfZmFjZXRzKGJhc2Vfc2l6ZSA9IDE0KQoKZ2dhcnJhbmdlKHNhbF9jb21wX3RlbXBzLCBzYWxfY29tcF9zYWwsIG5yb3cgPSAyLCBjb21tb24ubGVnZW5kID0gVCwgbGVnZW5kID0gInJpZ2h0IikKCiMgc2FsX2NvbXBzICU+JSAgCiMgICBzZWxlY3Qoc2l0ZSwgc2FsaW5pdHksIHNlYXNvbiwgcmVnaW9uLCBjb2xsZWN0aW9uX3RlbXAsIGNvbGxlY3Rpb25fc2FsaW5pdHkpICU+JSAKIyAgIGRpc3RpbmN0KCkgJT4lIAojICAgZ2dwbG90KGFlcyh4ID0gY29sbGVjdGlvbl9zYWxpbml0eSwgeSA9IGNvbGxlY3Rpb25fdGVtcCwgY29sb3VyID0gc2l0ZSkpICsgCiMgICBmYWNldF9ncmlkKHJlZ2lvbn4uKSArIAojICAgZ2VvbV9wb2ludChzaXplID0gNCkgKyAKIyAgICNzdGF0X2VsbGlwc2UoKSArCiMgICAjZ2VvbV9wYXRoKGFycm93ID0gYXJyb3cobGVuZ3RoID0gdW5pdCgwLjEsICJpbmNoZXMiKSwgdHlwZSA9ICJjbG9zZWQiKSkgKyAKIyAgIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAojICAgdGhlbWVfbWF0dF9mYWNldHMoYmFzZV9zaXplID0gMTQpCmBgYAoKIyMgQ3JpdGljYWwgVGhlcm1hbCBMaW1pdHMKCkEgdG90YWwgb2YgYHIgZGltKGFsbF9kYXRhKVsxXWAgaW5kaXZpZHVhbHMgd2VyZSBleGFtaW5lZC4gQ3JpdGljYWwgdGhlcm1hbCBsaW1pdHMgYW5kIGJvZHkgc2l6ZSBtZWFzdXJlbWVudHMgd2VyZSBtYWRlIGJlZm9yZSBpbmRpdmlkdWFscyB3ZXJlIHByZXNlcnZlZCBpbiBldGhhbm9sLiBXZSBleGNsdWRlZCBkYXRhIGZvciBgciBkaW0oZXhjbHVkZWQpWzFdYCBpbmRpdmlkdWFscywgZGV0YWlsZWQgYmVsb3cuIFRoZXNlIGluZGl2aWR1YWxzIGhhZCBlaXRoZXIgdmVyeSBsb3cgQ1RtYXggb3Igd2VyZSwgdXBvbiByZS1leGFtaW5hdGlvbiBvZiBwaG90b2dyYXBocywgaWRlbnRpZmllZCBhcyBqdXZlbmlsZXMgaW5zdGVhZCBvZiBtYXR1cmUgZmVtYWxlcy4gIAoKYGBge3IgZXhjbHVkZWQtaW5kc30KZXhjbHVkZWQgJT4lIAogIHNlbGVjdChyZWdpb24sIHNpdGUsIHNlYXNvbiwgY29sbGVjdGlvbl90ZW1wLCBjb2xsZWN0aW9uX3NhbGluaXR5LCByZXBsaWNhdGUsIHR1YmUsIGN0bWF4LCBzaXplKSAlPiUgCiAga25pdHI6OmthYmxlKGFsaWduID0gImMiKQpgYGAKCkNyaXRpY2FsIHRoZXJtYWwgbWF4aW1hIChDVG1heCkgd2FzIG1lYXN1cmVkIHVzaW5nIGEgY3VzdG9tIHNldHVwLiBUaGUgbWV0aG9kIHVzZXMgYSBzdGFuZGFyZCBkeW5hbWljIHJhbXBpbmcgYXNzYXkgdG8gZGV0ZXJtaW5lIHRoZSBtYXhpbXVtIHRlbXBlcmF0dXJlIGluZGl2aWR1YWxzIGNvdWxkIHN1c3RhaW4gbm9ybWFsIGZ1bmN0aW9uaW5nLiBUaGlzIGRpZmZlcnMgZnJvbSBsZXRoYWwgdGVtcGVyYXR1cmVzLCBhbmQgaW5kZWVkLCBhbGwgaW5kaXZpZHVhbHMgb2JzZXJ2ZWQgc28gZmFyIHJlY292ZXJlZCBmb2xsb3dpbmcgdGhlIGFzc2F5LgoKSW5kaXZpZHVhbHMgd2VyZSByZXN0ZWQgZm9yIG9uZSBob3VyIGFmdGVyIGNvbGxlY3Rpb24gYmVmb3JlIHRoZSBhc3NheS4gRHVyaW5nIHRoZSBhc3NheSwgY29wZXBvZHMgd2VyZSBoZWxkIGluIDAuMiB1bSBmaWx0ZXJlZCBzZWF3YXRlciwgYWRqdXN0ZWQgdG8gbWF0Y2ggdGhlIHNhbGluaXR5IGF0IHRoZSB0aW1lIG9mIGNvbGxlY3Rpb24gd2l0aCBib3R0bGVkIHNwcmluZyB3YXRlci4gRHVyaW5nIHRoZSBhc3NheSwgc2V2ZXJhbCAnY29udHJvbCcgaW5kaXZpZHVhbHMgd2VyZSBtYWludGFpbmVkIGluIHRoaXMgYWRqdXN0ZWQgc2FsaW5pdHkgc29sdXRpb24sIGJ1dCBkaWQgbm90IGV4cGVyaWVuY2UgdGhlIHRlbXBlcmF0dXJlIHJhbXAsIHRvIGVuc3VyZSB0aGF0IHRoZXJlIHdhcyBubyBiYWNrZ3JvdW5kIG1vcnRhbGl0eS4KClNob3duIGJlbG93IGFyZSB0aGUgbWVhc3VyZWQgQ1RtYXggdmFsdWVzLiBOb3RlOiBDVG1heCB2YWx1ZXMgZm9yIHRoZSBlYXJseSBzZWFzb24gS2V5IExhcmdvIGNvcGVwb2RzIHdlcmUgY29sbGVjdGVkIGF0IHRoZSBlbmQgb2YgRmVicnVhcnkgMjAyMyBhcyBwYXJ0IG9mIGEgc2VwYXJhdGUgcHJvamVjdC4gQm9keSBzaXplIHZhbHVlcyB3ZXJlIG5vdCBtZWFzdXJlZCBkdXJpbmcgdGhpcyBwcm9qZWN0LCBub3Igd2VyZSBjb3BlcG9kcyBpbmRpdmlkdWFsbHkgcHJlc2VydmVkIGFmdGVyIHRoZSBleHBlcmltZW50cy4gVGhlc2UgZWFybHkgc2Vhc29uIENUbWF4IHZhbHVlcyBhcmUgaW5jbHVkZWQgYXMgYSBwb2ludCBvZiBjb21wYXJpc29uLgoKYGBge3Igc2Vhc29uYWwtY3QtbWF4fQptZWFuX2N0bWF4ID0gZnVsbF9kYXRhICU+JSAKICBncm91cF9ieShzaXRlLCBzZWFzb24pICU+JSAKICBzdW1tYXJpemUobWVhbl9jdG1heCA9IG1lYW4oY3RtYXgpKQoKZ2dwbG90KGZ1bGxfZGF0YSwgYWVzKHggPSBzZWFzb24sIHkgPSBjdG1heCwgY29sb3VyID0gc2l0ZSkpICsgCiAgZ2VvbV9saW5lKGRhdGEgPSBtZWFuX2N0bWF4LCAKICAgICAgICAgICAgYWVzKHkgPSBtZWFuX2N0bWF4LCBncm91cCA9IHNpdGUpLAogICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX2RvZGdlKHdpZHRoID0gMC40KSwKICAgICAgICAgICAgbGluZXdpZHRoID0gMSkgKyAKICBnZW9tX3BvaW50KHBvc2l0aW9uID0gcG9zaXRpb25faml0dGVyZG9kZ2Uoaml0dGVyLndpZHRoID0gMC4xLCBqaXR0ZXIuaGVpZ2h0ID0gMCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZG9kZ2Uud2lkdGggPSAwLjQpLAogICAgICAgICAgICAgYWxwaGEgPSAwLjMpICsgCiAgZ2VvbV9wb2ludChkYXRhID0gbWVhbl9jdG1heCwgCiAgICAgICAgICAgICBhZXMoeSA9IG1lYW5fY3RtYXgpLAogICAgICAgICAgICAgcG9zaXRpb24gPSBwb3NpdGlvbl9kb2RnZSh3aWR0aCA9IDAuNCksCiAgICAgICAgICAgICBzaXplID0gNCkgKyAKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNpdGVfY29scykgKyAKICBsYWJzKHkgPSAiQ1RtYXggKMKwQykiLAogICAgICAgeCA9ICJTZWFzb24iKSArCiAgdGhlbWVfbWF0dCgpICsgCiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gInJpZ2h0IiwgCiAgICAgICAgbGVnZW5kLnRpdGxlLmFsaWduID0gMC4xMjUpCmBgYAoKIyMgV2FybWluZyB0b2xlcmFuY2UKCldhcm1pbmcgdG9sZXJhbmNlIHdhcyBjYWxjdWxhdGVkIGFzIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gbWVhc3VyZWQgQ1RtYXggdmFsdWVzIGFuZCB0aGUgY29sbGVjdGlvbiB0ZW1wZXJhdHVyZS4gTG93ZXIgd2FybWluZyB0b2xlcmFuY2UgdmFsdWVzIGluZGljYXRlIHRoYXQgcG9wdWxhdGlvbnMgd2VyZSBuZWFyZXIgdG8gdGhlaXIgdXBwZXIgdGhlcm1hbCBsaW1pdHMsIGFuZCBtYXkgdGhlcmVmb3JlIGJlIG1vcmUgdnVsbmVyYWJsZSB0byBhZGRpdGlvbmFsIHdhcm1pbmcuIAoKYGBge3Igc2Vhc29uYWwtd2FybWluZy10b2x9Cm1lYW5fd3QgPSBmdWxsX2RhdGEgJT4lIAogIGdyb3VwX2J5KHNpdGUsIHNlYXNvbikgJT4lIAogIHN1bW1hcml6ZShtZWFuX3d0ID0gbWVhbih3YXJtaW5nX3RvbCkpCgpnZ3Bsb3QoZnVsbF9kYXRhLCBhZXMoeCA9IHNlYXNvbiwgeSA9IHdhcm1pbmdfdG9sLCBjb2xvdXIgPSBzaXRlKSkgKyAKICBnZW9tX2xpbmUoZGF0YSA9IG1lYW5fd3QsIAogICAgICAgICAgICBhZXMoeSA9IG1lYW5fd3QsIGdyb3VwID0gc2l0ZSksCiAgICAgICAgICAgIHBvc2l0aW9uID0gcG9zaXRpb25fZG9kZ2Uod2lkdGggPSAwLjQpLAogICAgICAgICAgICBsaW5ld2lkdGggPSAxKSArIAogIGdlb21fcG9pbnQocG9zaXRpb24gPSBwb3NpdGlvbl9qaXR0ZXJkb2RnZShqaXR0ZXIud2lkdGggPSAwLjEsIGppdHRlci5oZWlnaHQgPSAwLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkb2RnZS53aWR0aCA9IDAuNCksCiAgICAgICAgICAgICBhbHBoYSA9IDAuMykgKyAKICBnZW9tX3BvaW50KGRhdGEgPSBtZWFuX3d0LCAKICAgICAgICAgICAgIGFlcyh5ID0gbWVhbl93dCksCiAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX2RvZGdlKHdpZHRoID0gMC40KSwKICAgICAgICAgICAgIHNpemUgPSA0KSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeSA9ICJXYXJtaW5nIFRvbGVyYW5jZSAowrBDKSIsCiAgICAgICB4ID0gIlNlYXNvbiIpICsKICB0aGVtZV9tYXR0KCkgKyAKICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSAicmlnaHQiLCAKICAgICAgICBsZWdlbmQudGl0bGUuYWxpZ24gPSAwLjEyNSkKYGBgCgojIyBCb2R5IFNpemUKCkZvbGxvd2luZyB0aGUgQ1RtYXggYXNzYXksIGluZGl2aWR1YWxzIHdlcmUgcGhvdG9ncmFwaGVkIGZvciBib2R5IHNpemUgbWVhc3VyZW1lbnRzLiBQcm9zb21lIGxlbmd0aHMgd2VyZSBtZWFzdXJlZCBmcm9tIHRoZXNlIHBob3RvZ3JhcGhzIHVzaW5nIGEgc2NhbGUgbWljcm9tZXRlciBhbmQgdGhlIHNvZnR3YXJlIEltYWdlSi4gVGhlc2UgbWVhc3VyZW1lbnRzIGFyZSBzaG93biBiZWxvdy4KCmBgYHtyIHNlYXNvbmFsLWJvZHktc2l6ZX0KbWVhbl9zaXplID0gZnVsbF9kYXRhICU+JSAKICBncm91cF9ieShzaXRlLCBzZWFzb24pICU+JSAKICBzdW1tYXJpemUobWVhbl9zaXplID0gbWVhbihzaXplKSkKCmdncGxvdChmdWxsX2RhdGEsIGFlcyh4ID0gc2Vhc29uLCB5ID0gc2l6ZSwgY29sb3VyID0gc2l0ZSkpICsgCiAgZ2VvbV9saW5lKGRhdGEgPSBtZWFuX3NpemUsIAogICAgICAgICAgICBhZXMoeSA9IG1lYW5fc2l6ZSwgZ3JvdXAgPSBzaXRlKSwKICAgICAgICAgICAgcG9zaXRpb24gPSBwb3NpdGlvbl9kb2RnZSh3aWR0aCA9IDAuNCksCiAgICAgICAgICAgIGxpbmV3aWR0aCA9IDEpICsgCiAgZ2VvbV9wb2ludChwb3NpdGlvbiA9IHBvc2l0aW9uX2ppdHRlcmRvZGdlKGppdHRlci53aWR0aCA9IDAuMSwgaml0dGVyLmhlaWdodCA9IDAsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRvZGdlLndpZHRoID0gMC40KSwKICAgICAgICAgICAgIGFscGhhID0gMC4zKSArIAogIGdlb21fcG9pbnQoZGF0YSA9IG1lYW5fc2l6ZSwgCiAgICAgICAgICAgICBhZXMoeSA9IG1lYW5fc2l6ZSksCiAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX2RvZGdlKHdpZHRoID0gMC40KSwKICAgICAgICAgICAgIHNpemUgPSA0KSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeSA9ICJQcm9zb21lIExlbmd0aCAobW0pIiwKICAgICAgIHggPSAiU2Vhc29uIikgKwogIHRoZW1lX21hdHQoKSArIAogIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9ICJyaWdodCIsIAogICAgICAgIGxlZ2VuZC50aXRsZS5hbGlnbiA9IDAuMTI1KQpgYGAKCiMjIyBTYWxpbml0eSBQYWlyIENvbXBhcmlzb25zIAoKYGBge3Igc2FsLXBhaXItdHJhaXRzfQpzYWxfY29tcF9jdG1heF9wbG90ID0gc2FsX2NvbXBzICU+JSAKICBnZ3Bsb3QoYWVzKHggPSBzYWxpbml0eSwgeSA9IGN0bWF4LCBjb2xvdXIgPSBzZWFzb24sIGdyb3VwID0gc2Vhc29uKSkgKyAKICBmYWNldF93cmFwKHJlZ2lvbn4uKSArIAogIGdlb21fcG9pbnQoc2l6ZSA9IDIsCiAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX2RvZGdlKHdpZHRoID0gMC4yKSkgKyAKICAjZ2VvbV9saW5lKHNpemUgPSAxLjUpICsgCiAgc2NhbGVfY29sb3VyX21hbnVhbCh2YWx1ZXMgPSBzZWFzb25fY29scykgKyAKICBsYWJzKHkgPSAiQ1RtYXggKMKwQykiLAogICAgICAgeCA9ICIiKSArIAogIHRoZW1lX21hdHRfZmFjZXRzKGJhc2Vfc2l6ZSA9IDE0KQoKc2FsX2NvbXBfc2l6ZV9wbG90ID0gc2FsX2NvbXBzICU+JSAKICBnZ3Bsb3QoYWVzKHggPSBzYWxpbml0eSwgeSA9IHNpemUsIGNvbG91ciA9IHNlYXNvbiwgZ3JvdXAgPSBzZWFzb24pKSArIAogIGZhY2V0X3dyYXAocmVnaW9ufi4pICsgCiAgZ2VvbV9wb2ludChzaXplID0gMiwgCiAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX2RvZGdlKHdpZHRoID0gMC4yKSkgKyAKICAjZ2VvbV9saW5lKHNpemUgPSAxLjUpICsgCiAgc2NhbGVfY29sb3VyX21hbnVhbCh2YWx1ZXMgPSBzZWFzb25fY29scykgKyAKICBsYWJzKHkgPSAiUHJvc29tZSBMZW5ndGggKG1tKSIsCiAgICAgICB4ID0gIiIpICsgCiAgdGhlbWVfbWF0dF9mYWNldHMoYmFzZV9zaXplID0gMTQpCgpnZ2FycmFuZ2Uoc2FsX2NvbXBfY3RtYXhfcGxvdCwgc2FsX2NvbXBfc2l6ZV9wbG90LCBucm93ID0gMiwgY29tbW9uLmxlZ2VuZCA9IFQsIGxlZ2VuZCA9ICJyaWdodCIpCgojIyMKCnNhbF9jb21wX2N0bWF4Lm1vZGVsID0gbG0oY3RtYXggfiBjb2xsZWN0aW9uX3RlbXAsIGRhdGEgPSBzYWxfY29tcHMpCiMgc3VtbWFyeShjdG1heF90ZW1wLm1vZGVsKQojIGNhcjo6QW5vdmEoY3RtYXhfdGVtcC5tb2RlbCkKc2FsX2NvbXBfY3RtYXhfcmVzaWRzID0gcmVzaWR1YWxzKHNhbF9jb21wX2N0bWF4Lm1vZGVsKQoKc2FsX2NvbXBfc2l6ZS5tb2RlbCA9IGxtKHNpemUgfiBjb2xsZWN0aW9uX3RlbXAsIGRhdGEgPSBzYWxfY29tcHMpCiMgc3VtbWFyeShzaXplX3RlbXAubW9kZWwpCiMgY2FyOjpBbm92YShzaXplX3RlbXAubW9kZWwpCnNhbF9jb21wX3NpemVfcmVzaWRzID0gcmVzaWR1YWxzKHNhbF9jb21wX3NpemUubW9kZWwpCgpzYWxfY29tcF9jdG1heF9yZXNpZF9wbG90ID0gc2FsX2NvbXBzICU+JQogIG11dGF0ZShjdG1heF9yZXNpZHMgPSBzYWxfY29tcF9jdG1heF9yZXNpZHMsCiAgICAgICAgIHNpemVfcmVzaWRzID0gc2FsX2NvbXBfc2l6ZV9yZXNpZHMpICU+JQogIGdncGxvdChhZXMoeCA9IHNhbGluaXR5LCB5ID0gY3RtYXhfcmVzaWRzLCBjb2xvdXIgPSBzZWFzb24sIGdyb3VwID0gc2Vhc29uKSkgKwogIGZhY2V0X3dyYXAocmVnaW9ufi4pICsKICBnZW9tX3BvaW50KHNpemUgPSAyLAogICAgICAgICAgICAgcG9zaXRpb24gPSBwb3NpdGlvbl9kb2RnZSh3aWR0aCA9IDAuNSkpICsKICAjZ2VvbV9saW5lKHNpemUgPSAxLjUpICsKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNlYXNvbl9jb2xzKSArCiAgbGFicyh5ID0gIkNUbWF4IFxuUmVzaWR1YWxzIiwKICAgICAgIHggPSAiIikgKwogIHRoZW1lX21hdHRfZmFjZXRzKGJhc2Vfc2l6ZSA9IDE0KQoKc2FsX2NvbXBfc2l6ZV9yZXNpZF9wbG90ID0gc2FsX2NvbXBzICU+JQogIG11dGF0ZShjdG1heF9yZXNpZHMgPSBzYWxfY29tcF9jdG1heF9yZXNpZHMsCiAgICAgICAgIHNpemVfcmVzaWRzID0gc2FsX2NvbXBfc2l6ZV9yZXNpZHMpICU+JQogIGdncGxvdChhZXMoeCA9IHNhbGluaXR5LCB5ID0gc2l6ZV9yZXNpZHMsIGNvbG91ciA9IHNlYXNvbiwgZ3JvdXAgPSBzZWFzb24pKSArCiAgZmFjZXRfd3JhcChyZWdpb25+LikgKwogIGdlb21fcG9pbnQoc2l6ZSA9IDIsCiAgICAgICAgICAgICBwb3NpdGlvbiA9IHBvc2l0aW9uX2RvZGdlKHdpZHRoID0gMC41KSkgKwogICNnZW9tX2xpbmUoc2l6ZSA9IDEuNSkgKwogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2Vhc29uX2NvbHMpICsKICBsYWJzKHkgPSAiUHJvc29tZSBMZW5ndGggXG5SZXNpZHVhbHMiLAogICAgICAgeCA9ICIiKSArCiAgdGhlbWVfbWF0dF9mYWNldHMoYmFzZV9zaXplID0gMTQpCgojZ2dhcnJhbmdlKHNhbF9jb21wX2N0bWF4X3Jlc2lkX3Bsb3QsIHNhbF9jb21wX3NpemVfcmVzaWRfcGxvdCwgbnJvdyA9IDIsIGNvbW1vbi5sZWdlbmQgPSBULCBsZWdlbmQgPSAicmlnaHQiKQpgYGAKCgojIyBUcmFpdCBDb3JyZWxhdGlvbnMKCldlIGV4cGVjdCB0aGF0IGNvbGxlY3Rpb25zIGZyb20gd2FybWVyIHdhdGVycyBzaG91bGQgeWllbGQgY29wZXBvZHMgd2l0aCBoaWdoZXIgdGhlcm1hbCBsaW1pdHMgYW5kIHNtYWxsZXIgYm9keSBzaXplcy4KCmBgYHtyIHRlbXAtY29ycywgZmlnLndpZHRoPTE1LCBmaWcuaGVpZ2h0PTZ9CmN0bWF4X3RlbXBfcGxvdCA9IGdncGxvdChmdWxsX2RhdGEsIGFlcyh4ID0gY29sbGVjdGlvbl90ZW1wLCB5ID0gY3RtYXgpKSArIAogIGdlb21fc21vb3RoKG1ldGhvZCA9ICJsbSIsIHNlID0gVCwKICAgICAgICAgICAgICBsaW5ld2lkdGggPSAyLCAKICAgICAgICAgICAgICBjb2xvdXIgPSAiZ3JleSIpICsgCiAgZ2VvbV9wb2ludChhZXMoY29sb3VyID0gc2l0ZSksIAogICAgICAgICAgICAgc2l6ZSA9IDIsIGFscGhhID0gMC43KSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeSA9ICJDVG1heCAowrBDKSIsCiAgICAgICB4ID0gIkNvbGxlY3Rpb24gVGVtcC4gKMKwQykiKSArCiAgdGhlbWVfbWF0dCgpICsgCiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gInJpZ2h0IikKCnNpemVfdGVtcF9wbG90ID0gZ2dwbG90KGZ1bGxfZGF0YSwgYWVzKHggPSBjb2xsZWN0aW9uX3RlbXAsIHkgPSBzaXplKSkgKyAKICBnZW9tX3Ntb290aChtZXRob2QgPSAibG0iLCBzZSA9IFQsCiAgICAgICAgICAgICAgbGluZXdpZHRoID0gMiwgCiAgICAgICAgICAgICAgY29sb3VyID0gImdyZXkiKSArIAogIGdlb21fcG9pbnQoYWVzKGNvbG91ciA9IHNpdGUpLCAKICAgICAgICAgICAgIHNpemUgPSAyLCBhbHBoYSA9IDAuNykgKyAKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNpdGVfY29scykgKyAKICBsYWJzKHkgPSAiUHJvc29tZSBMZW5ndGggKG1tKSIsCiAgICAgICB4ID0gIkNvbGxlY3Rpb24gVGVtcC4gKMKwQykiKSArCiAgdGhlbWVfbWF0dCgpICsgCiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gInJpZ2h0IikKCnd0X3RlbXBfcGxvdCA9IGdncGxvdChmdWxsX2RhdGEsIGFlcyh4ID0gY29sbGVjdGlvbl90ZW1wLCB5ID0gd2FybWluZ190b2wpKSArIAogIGdlb21fc21vb3RoKG1ldGhvZCA9ICJsbSIsIHNlID0gVCwKICAgICAgICAgICAgICBsaW5ld2lkdGggPSAyLCAKICAgICAgICAgICAgICBjb2xvdXIgPSAiZ3JleSIpICsgCiAgZ2VvbV9wb2ludChhZXMoY29sb3VyID0gc2l0ZSksIAogICAgICAgICAgICAgc2l6ZSA9IDIsIGFscGhhID0gMC43KSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeSA9ICJXYXJtaW5nIFRvbGVyYW5jZSAowrBDKSIsCiAgICAgICB4ID0gIkNvbGxlY3Rpb24gVGVtcC4gKMKwQykiKSArCiAgdGhlbWVfbWF0dCgpICsgCiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gInJpZ2h0IikKCmdnYXJyYW5nZShjdG1heF90ZW1wX3Bsb3QsIHd0X3RlbXBfcGxvdCwgc2l6ZV90ZW1wX3Bsb3QsIGNvbW1vbi5sZWdlbmQgPSBULCBsZWdlbmQgPSAiYm90dG9tIiwgbnJvdyA9IDEpCmBgYAoKT2YgcGFydGljdWxhciBpbnRlcmVzdCBpcyB0aGUgcmVsYXRpb25zaGlwIGJldHdlZW4gcHJvc29tZSBsZW5ndGggYW5kIENUbWF4LiBJbiBtYW55IGNhc2VzLCBsYXJnZXIgYm9keSBzaXplcyBhcmUgYXNzb2NpYXRlZCB3aXRoIGNvbGQgYWRhcHRhdGlvbi9hY2NsaW1hdGlvbi4gV2UgbWF5IHRoZXJlZm9yZSBzZWUgdGhpcyBwYXR0ZXJuIGVtZXJnZSBhY3Jvc3MgcG9wdWxhdGlvbnMgb3Igc2Vhc29ucy4gSWYgcG9wdWxhdGlvbnMgY29udGFpbiBhIG1peCBvZiBjb2xkLSBhbmQgd2FybS1hZGFwdGVkIGdlbm90eXBlcywgaG93ZXZlciwgd2UgbWlnaHQgYWxzbyBzZWUgdGhpcyByZWxhdGlvbnNoaXAgZW1lcmdlICoqd2l0aGluKiogaW5kaXZpZHVhbCBjb2xsZWN0aW9ucy4gU2hvd24gYmVsb3cgaXMgdGhlIHJlbGF0aW9uc2hpcCBiZXR3ZWVuIHByb3NvbWUgbGVuZ3RoIGFuZCBDVG1heCBmb3IgdGhlIGluZGl2aWR1YWxzIG1lYXN1cmVkIHRodXMgZmFyLiBJbmRpdmlkdWFsIHJlZ3Jlc3Npb24gbGluZXMgZm9yIGVhY2ggc2l0ZSBhcmUgYWxzbyBpbmNsdWRlZC4gTm90ZSB0aGF0IHJhdyBDVG1heCBhbmQgYm9keSBzaXplIHZhbHVlcyBhcmUgc2hvd24sIHJhdGhlciB0aGFuIG1ldHJpY3MgbGlrZSByZXNpZHVhbHMgZnJvbSBhIHN0YXRpc3RpY2FsIG1vZGVsIGNvcnJlY3RpbmcgZm9yIHZhcmlhdGlvbiBpbiBjb2xsZWN0aW9uIHRlbXBlcmF0dXJlLgoKYGBge3IgY3RtYXgtdnMtc2l6ZSwgZmlnLndpZHRoPTYsIGZpZy5oZWlnaHQ9MTB9CnVuaXZlcnNhbF9zaXplID0gZnVsbF9kYXRhICU+JSAKICBnZ3Bsb3QoYWVzKHggPSBzaXplLCB5ID0gY3RtYXgpKSArIAogICMgZ2VvbV9zbW9vdGgoZGF0YSA9IGZpbHRlcihmdWxsX2RhdGEsIGN0bWF4ID4gMzEpLCAKICAjICAgICAgICAgICAgIGFlcyh4ID0gc2l6ZSwgeSA9IGN0bWF4KSwKICAjICAgICAgICAgICAgIG1ldGhvZCA9ICJsbSIsIAogICMgICAgICAgICAgICAgY29sb3VyID0gImdyZXk2MCIsIAogICMgICAgICAgICAgICAgc2UgPSBGLAogICMgICAgICAgICAgICAgbGluZXdpZHRoID0gMikgKyAKICBnZW9tX3Ntb290aChtZXRob2QgPSAibG0iLCBzZSA9IFQsCiAgICAgICAgICAgICAgbGluZXdpZHRoID0gMiwKICAgICAgICAgICAgICBjb2xvdXIgPSAiZ3JleTcwIikgKyAKICBnZW9tX3BvaW50KGFlcyhjb2xvdXIgPSBzaXRlKSwKICAgICAgICAgICAgIHNpemUgPSAyLCBhbHBoYSA9IDAuNykgKyAKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNpdGVfY29scykgKyAKICBsYWJzKHkgPSAiQ1RtYXggKMKwQykiLAogICAgICAgeCA9ICIiKSArCiAgdGhlbWVfbWF0dChiYXNlX3NpemUgPSAxNCkgKyAKICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSAicmlnaHQiLAogICAgICAgIGF4aXMudGl0bGUueCA9IGVsZW1lbnRfYmxhbmsoKSkKCnBvcF9zaXplID0gZnVsbF9kYXRhICU+JSAKICBnZ3Bsb3QoYWVzKHggPSBzaXplLCB5ID0gY3RtYXgsIGNvbG91ciA9IHNpdGUsIGdyb3VwID0gc2Vhc29uKSkgKyAKICBmYWNldF93cmFwKHNpdGV+LikgKyAKICAjIGdlb21fc21vb3RoKGRhdGEgPSBmaWx0ZXIoZnVsbF9kYXRhLCBjdG1heCA+IDMxKSwgCiAgIyAgICAgICAgICAgICBhZXMoeCA9IHNpemUsIHkgPSBjdG1heCksCiAgIyAgICAgICAgICAgICBtZXRob2QgPSAibG0iLCAKICAjICAgICAgICAgICAgIGNvbG91ciA9ICJncmV5NjAiLCAKICAjICAgICAgICAgICAgIHNlID0gRiwKICAjICAgICAgICAgICAgIGxpbmV3aWR0aCA9IDIpICsgCiAgZ2VvbV9wb2ludChzaXplID0gMS4zLCBhbHBoYSA9IDAuMykgKyAKICBnZW9tX3Ntb290aChtZXRob2QgPSAibG0iLCBzZSA9IEYsCiAgICAgICAgICAgICAgbGluZXdpZHRoID0gMSkgKyAKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNpdGVfY29scykgKyAKICBzY2FsZV94X2NvbnRpbnVvdXMoYnJlYWtzID0gYygwLjYsIDAuOCwgMSkpICsgCiAgbGFicyh5ID0gIkNUbWF4ICjCsEMpIiwKICAgICAgIHggPSAiUHJvc29tZSBMZW5ndGggKG1tKSIpICsKICB0aGVtZV9tYXR0KGJhc2Vfc2l6ZSA9IDE0KSArIAogIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9ICJyaWdodCIpCgpnZ2FycmFuZ2UodW5pdmVyc2FsX3NpemUsIHBvcF9zaXplLCBjb21tb24ubGVnZW5kID0gVCwgbGVnZW5kID0gIm5vbmUiLCBucm93ID0gMikKYGBgCgpgYGB7ciBpbmNsdWRlID0gRn0KZmlsdGVyZWRfZGF0YSA9IGZ1bGxfZGF0YSAlPiUgCiAgZHJvcF9uYShzaXplLCBjdG1heCkKCmN0bWF4X3RlbXAubW9kZWwgPSBsbShjdG1heCB+IGNvbGxlY3Rpb25fdGVtcCwgZGF0YSA9IGZpbHRlcmVkX2RhdGEpCmN0bWF4X3Jlc2lkcyA9IHJlc2lkdWFscyhjdG1heF90ZW1wLm1vZGVsKQoKc2l6ZV90ZW1wLm1vZGVsID0gbG0oc2l6ZSB+IGNvbGxlY3Rpb25fdGVtcCwgZGF0YSA9IGZpbHRlcmVkX2RhdGEpCnNpemVfcmVzaWRzID0gcmVzaWR1YWxzKHNpemVfdGVtcC5tb2RlbCkKCnVuaXZlcnNhbF9yZXNpZHMgPSBmaWx0ZXJlZF9kYXRhICU+JSAKICBtdXRhdGUoY3RtYXhfcmVzaWRzID0gY3RtYXhfcmVzaWRzLAogICAgICAgICBzaXplX3Jlc2lkcyA9IHNpemVfcmVzaWRzKSAlPiUgCiAgZ2dwbG90KGFlcyh4ID0gc2l6ZV9yZXNpZHMsIHkgPSBjdG1heF9yZXNpZHMpKSArIAogICMgZ2VvbV9zbW9vdGgoZGF0YSA9IGZpbHRlcihmdWxsX2RhdGEsIGN0bWF4ID4gMzEpLCAKICAjICAgICAgICAgICAgIGFlcyh4ID0gc2l6ZSwgeSA9IGN0bWF4KSwKICAjICAgICAgICAgICAgIG1ldGhvZCA9ICJsbSIsIAogICMgICAgICAgICAgICAgY29sb3VyID0gImdyZXk2MCIsIAogICMgICAgICAgICAgICAgc2UgPSBGLAogICMgICAgICAgICAgICAgbGluZXdpZHRoID0gMikgKyAKICBnZW9tX3Ntb290aChtZXRob2QgPSAibG0iLCBzZSA9IFQsCiAgICAgICAgICAgICAgbGluZXdpZHRoID0gMiwKICAgICAgICAgICAgICBjb2xvdXIgPSAiZ3JleTcwIikgKyAKICBnZW9tX3BvaW50KGFlcyhjb2xvdXIgPSBzaXRlKSwKICAgICAgICAgICAgIHNpemUgPSAyLCBhbHBoYSA9IDAuNykgKyAKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNpdGVfY29scykgKyAKICBsYWJzKHkgPSAiQ1RtYXggKMKwQykiLAogICAgICAgeCA9ICIiKSArCiAgdGhlbWVfbWF0dChiYXNlX3NpemUgPSAxNCkgKyAKICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSAicmlnaHQiLAogICAgICAgIGF4aXMudGl0bGUueCA9IGVsZW1lbnRfYmxhbmsoKSkKCnBvcF9yZXNpZHMgPSBmaWx0ZXJlZF9kYXRhICU+JSAKICBtdXRhdGUoY3RtYXhfcmVzaWRzID0gY3RtYXhfcmVzaWRzLAogICAgICAgICBzaXplX3Jlc2lkcyA9IHNpemVfcmVzaWRzKSAlPiUgCiAgZ2dwbG90KGFlcyh4ID0gc2l6ZV9yZXNpZHMsIHkgPSBjdG1heF9yZXNpZHMsIGNvbG91ciA9IHNpdGUsIGdyb3VwID0gc2Vhc29uKSkgKyAKICBmYWNldF93cmFwKHNpdGV+LikgKyAKICAjIGdlb21fc21vb3RoKGRhdGEgPSBmaWx0ZXIoZnVsbF9kYXRhLCBjdG1heCA+IDMxKSwgCiAgIyAgICAgICAgICAgICBhZXMoeCA9IHNpemUsIHkgPSBjdG1heCksCiAgIyAgICAgICAgICAgICBtZXRob2QgPSAibG0iLCAKICAjICAgICAgICAgICAgIGNvbG91ciA9ICJncmV5NjAiLCAKICAjICAgICAgICAgICAgIHNlID0gRiwKICAjICAgICAgICAgICAgIGxpbmV3aWR0aCA9IDIpICsgCiAgZ2VvbV9wb2ludChzaXplID0gMS4zLCBhbHBoYSA9IDAuMykgKyAKICBnZW9tX3Ntb290aChtZXRob2QgPSAibG0iLCBzZSA9IEYsCiAgICAgICAgICAgICAgbGluZXdpZHRoID0gMSkgKyAKICBzY2FsZV9jb2xvdXJfbWFudWFsKHZhbHVlcyA9IHNpdGVfY29scykgKyAKICBzY2FsZV94X2NvbnRpbnVvdXMoYnJlYWtzID0gYygwLjYsIDAuOCwgMSkpICsgCiAgbGFicyh5ID0gIkNUbWF4ICjCsEMpIiwKICAgICAgIHggPSAiUHJvc29tZSBMZW5ndGggKG1tKSIpICsKICB0aGVtZV9tYXR0KGJhc2Vfc2l6ZSA9IDE0KSArIAogIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9ICJyaWdodCIpCgpnZ2FycmFuZ2UodW5pdmVyc2FsX3Jlc2lkcywgcG9wX3Jlc2lkcywgY29tbW9uLmxlZ2VuZCA9IFQsIGxlZ2VuZCA9ICJub25lIiwgbnJvdyA9IDIpCmBgYAoKYGBge3IgY3RtYXgtbW9kZWwsIGluY2x1ZGUgPSBGfQpjdG1heC5tb2RlbCA9IGxtZTQ6OmxtZXIoZGF0YSA9IGZ1bGxfZGF0YSwKICAgICAgICAgICBjdG1heCB+IGNvbGxlY3Rpb25fdGVtcCArIHNpemUgKyAoMXxzaXRlKSkKCnN1bW1hcnkoY3RtYXgubW9kZWwpCmNhcjo6QW5vdmEoY3RtYXgubW9kZWwpCmBgYAoKCiMjIFRyYWl0IFZhcmlhYmlsaXR5CgpTaG93biBiZWxvdyBpcyB0aGUgdHJhaXQgdmFyaWF0aW9uIChyYW5nZXMpIGZvciBlYWNoIHNpdGUuIFJhbmdlcyBhcmUgY2FsY3VsYXRlZCBmb3IgZWFjaCBzZWFzb24gc2VwYXJhdGVseS4KCmBgYHtyIHRyYWl0LXJhbmdlLXBsb3R9CnRyYWl0X3JhbmdlcyA9IGZ1bGxfZGF0YSAlPiUgCiAgZ3JvdXBfYnkoc2l0ZSwgc2Vhc29uLCBjb2xsZWN0aW9uX3RlbXAsIGNvbGxlY3Rpb25fc2FsaW5pdHksIGRveSwgbGF0KSAlPiUgCiAgc3VtbWFyaXNlKG1lYW5fY3RtYXggPSBtZWFuKGN0bWF4KSwKICAgICAgICAgICAgY3RtYXhfcmFuZ2UgPSBtYXgoY3RtYXgpIC0gbWluKGN0bWF4KSwKICAgICAgICAgICAgY3RtYXhfdmFyID0gdmFyKGN0bWF4KSwKICAgICAgICAgICAgbWVhbl9zaXplID0gbWVhbihzaXplKSwKICAgICAgICAgICAgc2l6ZV9yYW5nZSA9IG1heChzaXplKSAtIG1pbihzaXplKSwKICAgICAgICAgICAgc2l6ZV92YXIgPSB2YXIoc2l6ZSkpICU+JSAKICBtdXRhdGUocHJvcF9jdG1heF9yYW5nZSA9IGN0bWF4X3JhbmdlIC8gbWVhbl9jdG1heCwKICAgICAgICAgcHJvcF9zaXplX3JhbmdlID0gc2l6ZV9yYW5nZSAvIG1lYW5fc2l6ZSkKCmN0bWF4X3JhbmdlX3RlbXAgPSBnZ3Bsb3QodHJhaXRfcmFuZ2VzLCBhZXMoeCA9IGNvbGxlY3Rpb25fdGVtcCwgeSA9IGN0bWF4X3JhbmdlLCBjb2xvdXIgPSBzaXRlKSkgKyAKICBnZW9tX3BvaW50KHNpemUgPSAzKSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeSA9ICJDVG1heCBSYW5nZSAowrBDKSIsCiAgICAgICB4ID0gIkNvbGxlY3Rpb24gVGVtcC4gKMKwQykiKSArCiAgdGhlbWVfbWF0dCgpICsgCiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gInJpZ2h0IikKCmN0bWF4X3Zhcl90ZW1wID0gZ2dwbG90KHRyYWl0X3JhbmdlcywgYWVzKHggPSBjb2xsZWN0aW9uX3RlbXAsIHkgPSBjdG1heF92YXIsIGNvbG91ciA9IHNpdGUpKSArIAogIGdlb21fcG9pbnQoc2l6ZSA9IDMpICsgCiAgc2NhbGVfY29sb3VyX21hbnVhbCh2YWx1ZXMgPSBzaXRlX2NvbHMpICsgCiAgbGFicyh5ID0gIkNUbWF4IFJhbmdlICjCsEMpIiwKICAgICAgIHggPSAiQ29sbGVjdGlvbiBUZW1wLiAowrBDKSIpICsKICB0aGVtZV9tYXR0KCkgKyAKICB0aGVtZShsZWdlbmQucG9zaXRpb24gPSAicmlnaHQiKQoKc2l6ZV9yYW5nZV90ZW1wID0gZ2dwbG90KHRyYWl0X3JhbmdlcywgYWVzKHggPSBjb2xsZWN0aW9uX3RlbXAsIHkgPSBzaXplX3JhbmdlLCBjb2xvdXIgPSBzaXRlKSkgKyAKICBnZW9tX3BvaW50KHNpemUgPSAzKSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeSA9ICJTaXplIFJhbmdlIChtbSkiLAogICAgICAgeCA9ICJDb2xsZWN0aW9uIFRlbXAuICjCsEMpIikgKwogIHRoZW1lX21hdHQoKSArIAogIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9ICJyaWdodCIpCgpnZ2FycmFuZ2UoY3RtYXhfcmFuZ2VfdGVtcCwgc2l6ZV9yYW5nZV90ZW1wLCBjb21tb24ubGVnZW5kID0gVCwgbGVnZW5kID0gImJvdHRvbSIpCmBgYAoKQ2hhbmdlcyBpbiB0cmFpdCB2YXJpYW5jZSBtYXkgYmUgaW5kaWNhdGl2ZSBvZiBwaGVub3R5cGljIHNlbGVjdGlvbi4gSWYgc2VsZWN0aW9uIChhcyBvcHBvc2VkIHRvIGFjY2xpbWF0aW9uKSBhcmUgZHJpdmluZyBzZWFzb25hbCBjaGFuZ2VzLCB3ZSBtYXkgZXhwZWN0IHRvIHNlZSBhIHJlZHVjdGlvbiBpbiB2YXJpYW5jZSBpbiB0aGUgcGVhayBzYW1wbGVzIHJlbGF0aXZlIHRvIHRoZSBlYXJseSBzZWFzb24gc2FtcGxlcy4gTm90ZSB0aGF0IGVhcmx5IHNlYXNvbiBjb2xsZWN0aW9uIHRlbXBlcmF0dXJlcyB0aGlzIHllYXIgd2VyZSBoaWdoZXIgdGhhbiBleHBlY3RlZCwgZHJpdmVuIGJ5IGZhaXJseSBzdHJvbmcgaGVhdHdhdmVzIGluIHRoZSBOb3J0aCBBdGxhbnRpYy4gICAgCgpgYGB7ciBzZWFzb24tdmFyfQpnZ3Bsb3QodHJhaXRfcmFuZ2VzLCBhZXMoeCA9IHNlYXNvbiwgeSA9IGN0bWF4X3ZhciwgY29sb3VyID0gc2l0ZSkpICsgCiAgZ2VvbV9saW5lKGFlcyhncm91cCA9IHNpdGUpLCAKICAgICAgICAgICAgbGluZXdpZHRoID0gMS41KSArIAogIGdlb21fcG9pbnQoc2l6ZSA9IDMpICsgCiAgc2NhbGVfY29sb3VyX21hbnVhbCh2YWx1ZXMgPSBzaXRlX2NvbHMpICsgCiAgbGFicyh5ID0gIkNUbWF4IFZhcmlhbmNlIiwKICAgICAgIHggPSAiU2Vhc29uIikgKwogIHRoZW1lX21hdHQoKSArIAogIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9ICJyaWdodCIsIAogICAgICAgIGxlZ2VuZC50aXRsZS5hbGlnbiA9IDAuMTI1KQpgYGAKCmBgYHtyIHZhci1jaGFuZ2UtdGVtcC1jaGFuZ2UsIGluY2x1ZGUgPSBGfQp2YXJfY2hhbmdlX2RhdGEgPSB0cmFpdF9yYW5nZXMgJT4lICAKICBncm91cF9ieShzaXRlKSAlPiUgCiAgYXJyYW5nZShkb3kpICU+JSAgCiAgbXV0YXRlKHRlbXBfY2hhbmdlID0gY29sbGVjdGlvbl90ZW1wIC0gbGFnKGNvbGxlY3Rpb25fdGVtcCksCiAgICAgICAgIGN0bWF4X2NoYW5nZSA9IG1lYW5fY3RtYXggLSBsYWcobWVhbl9jdG1heCksCiAgICAgICAgIHZhcl9jaGFuZ2UgPSBjdG1heF92YXIgLSBsYWcoY3RtYXhfdmFyKSkgJT4lICAKICBzZWxlY3Qoc2l0ZSwgc2Vhc29uLCBkb3ksIGxhdCwgdGVtcF9jaGFuZ2UsIHZhcl9jaGFuZ2UsIGN0bWF4X2NoYW5nZSkKCmdncGxvdCh2YXJfY2hhbmdlX2RhdGEsIGFlcyh4ID0gdGVtcF9jaGFuZ2UsIHkgPSB2YXJfY2hhbmdlLCBjb2xvdXIgPSBzaXRlKSkgKwogIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDApICsgCiAgZ2VvbV92bGluZSh4aW50ZXJjZXB0ID0gMCkgKyAKICBnZW9tX3BvaW50KHNpemUgPSAzKSArIAogIHNjYWxlX2NvbG91cl9tYW51YWwodmFsdWVzID0gc2l0ZV9jb2xzKSArIAogIGxhYnMoeCA9ICJUZW1wZXJhdHVyZSBDaGFuZ2UgKMKwQykiLAogICAgICAgeSA9ICJDaGFuZ2UgaW4gQ1RtYXggVmFyaWFuY2UiKSArIAogIHRoZW1lX21hdHQoKSArIAogIHRoZW1lKGxlZ2VuZC5wb3NpdGlvbiA9ICJyaWdodCIsIAogICAgICAgIGxlZ2VuZC50aXRsZS5hbGlnbiA9IDAuMTI1KQpgYGAKCiMjIE5leHQgU3RlcHMKCkFmdGVyIHBoZW5vdHlwaW5nLCBlYWNoIGluZGl2aWR1YWwgd2FzIHByZXNlcnZlZCBpbiA5NSUgZXRoYW5vbC4gSW5kaXZpZHVhbCBETkEgbGlicmFyaWVzIHdpbGwgYmUgcHJlcGFyZWQgdXNpbmcgVHdpc3QgQmlvIDk2LXBsZXggcHJlcCBraXRzLCB0aGVuIHNlcXVlbmNlZCBvbiBhbiBJbGx1bWluYSBOb3ZhU2VxIFggUGx1cy4gVXNpbmcgdGhlIGxvdy1jb3ZlcmFnZSB3aG9sZSBnZW5vbWUgc2VxdWVuY2VzLCB3ZSB3aWxsIGV4YW1pbmUgc2Vhc29uYWwgcGF0dGVybnMgaW4gYWxsZWxlIGZyZXF1ZW5jeSBjaGFuZ2UsIGFuZCBjb21wYXJlIHRoZXNlIGZpbmUgc2NhbGUgdGVtcG9yYWwgcGF0dGVybnMgd2l0aCB0aGUgbGFyZ2VyIGxhdGl0dWRpbmFsIHBhdHRlcm5zIGluIGFsbGVsZSBmcmVxdWVuY3kgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgdGhlIHNhbWUgYWxsZWxlcyBkcml2aW5nIHJhcGlkIHNlYXNvbmFsIGFkYXB0YXRpb24gYXJlIGluIHBsYXkgb3ZlciBsYXJnZXIgc3BhdGlhbCAoYW5kIGxvbmdlciB0ZW1wb3JhbCkgc2NhbGVzLgoKIyMgTWlzYy4gRGV0YWlscwoKYGBge3IgdGVtcC1yZWNvcmQtcGxvdCwgZmlnLndpZHRoPTYsIGZpZy5oZWlnaHQ9Nn0KZ2dwbG90KHRlbXBfcmVjb3JkLCBhZXMoeCA9IG1pbnV0ZV9wYXNzZWQsIHkgPSB0ZW1wX0MsIGdyb3VwID0gZmFjdG9yKHJ1bikpKSArIAogIGdlb21fYWJsaW5lKHNsb3BlID0gMC4zLCBpbnRlcmNlcHQgPSBtZWFuKHRlbXBfcmVjb3JkW3RlbXBfcmVjb3JkJG1pbnV0ZV9pbnRlcnZhbCA9PSAwLCA4XSkpICsgCiAgZ2VvbV9hYmxpbmUoc2xvcGUgPSAwLjEsIGludGVyY2VwdCA9IG1lYW4odGVtcF9yZWNvcmRbdGVtcF9yZWNvcmQkbWludXRlX2ludGVydmFsID09IDAsIDhdKSkgKyAKICBnZW9tX2xpbmUobGluZXdpZHRoID0gMC4yLCBhbHBoYSA9IDAuOCkgKyAKICBnZW9tX3BvaW50KGRhdGEgPSBmdWxsX2RhdGEsIAogICAgICAgICAgICAgYWVzKHggPSB0aW1lLCB5ID0gY3RtYXggKyAwLjQpLAogICAgICAgICAgICAgc2l6ZSA9IDIsCiAgICAgICAgICAgICBzaGFwZSA9IDI1KSArCiAgbGFicyh4ID0gIlRpbWUgcGFzc2VkIChtaW51dGVzKSIsCiAgICAgICB5ID0gIlRlbXBlcmF0dXJlIChkZWdyZWVzIEMpIiwKICAgICAgIGZpbGwgPSAiVHJpYWwgTnVtYmVyIikgKyAKICBndWlkZXMoY29sb3VyID0gIm5vbmUiKSArIAogIHRoZW1lX21hdHQoYmFzZV9zaXplID0gMTYpICsgCiAgdGhlbWUobGVnZW5kLnBvc2l0aW9uID0gInJpZ2h0IikKYGBgCgpgYGB7ciByYW1wLXJlY29yZC1wbG90LCBmaWcud2lkdGg9NiwgZmlnLmhlaWdodD02fQpyYW1wX3JlY29yZDIgPSByYW1wX3JlY29yZCAlPiUgCiAgZ3JvdXBfYnkocnVuLCBtaW51dGVfaW50ZXJ2YWwpICU+JSAKICBzdW1tYXJpc2UobWVhbl9yYW1wID0gbWVhbihyYW1wX3Blcl9taW51dGUpKSAlPiUgCiAgdW5ncm91cCgpCgpnZ3Bsb3QocmFtcF9yZWNvcmQyLCBhZXMoeCA9IG1pbnV0ZV9pbnRlcnZhbCwgeSA9IG1lYW5fcmFtcCkpICsgCiAgZ2VvbV9obGluZSh5aW50ZXJjZXB0ID0gMC4zKSArIAogIGdlb21faGxpbmUoeWludGVyY2VwdCA9IDAuMSkgKyAKICAjZ2VvbV9wb2ludCgpICsgCiAgZ2VvbV9oZXgoYmlucyA9IDMwKSArIAogIHlsaW0oMCwgMC4zNSkgKyAKICBsYWJzKHkgPSAiUmFtcCBSYXRlIChkZWcuIEMgLyBtaW4uKSIsCiAgICAgICB4ID0gIlRpbWUgaW50byBydW4gKG1pbnV0ZSkiKSArIAogIHRoZW1lX21hdHQoYmFzZV9zaXplID0gMTYpIApgYGAK